package edu.upc.clase.demo.dao.impl;

import edu.upc.clase.demo.dao.CategoriaDao;
import edu.upc.clase.demo.entity.Categoria;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.sql.DataSource;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.dao.EmptyResultDataAccessException;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.simple.SimpleJdbcDaoSupport;
import org.springframework.stereotype.Repository;

/**
 *
 * @author Carlos
 */
@Repository
public class CategoriaDaoImpl extends SimpleJdbcDaoSupport implements CategoriaDao {

    private static Logger log = LoggerFactory.getLogger(CategoriaDaoImpl.class);

    @Autowired
    public CategoriaDaoImpl(DataSource dataSource) {
        log.info("Asignando el dataSource");
        setDataSource(dataSource);
    }

    @Override
    public Integer insertar(Categoria categoria) {
        getJdbcTemplate().update(
                "insert into categorias (nombre) values (?)",
                categoria.getNombre());
        return getSimpleJdbcTemplate().queryForInt("call identity()");
    }

    @Override
    public void actualizar(Categoria categoria) {
        getJdbcTemplate().update(
                "update categorias set nombre=? where id=?",
                categoria.getNombre(),categoria.getId());
    }

    @Override
    public void eliminar(Categoria categoria) {
        getJdbcTemplate().update(
                "delete from categorias where id = ?", categoria.getId());
    }

    @Override
    public Categoria buscar(Integer id) {
        try {
            return getSimpleJdbcTemplate().queryForObject(
                    "select id,nombre from categorias where id=?",
                    new BeanPropertyRowMapper<Categoria>(Categoria.class), id);
        } catch (EmptyResultDataAccessException e) {
            return null;
        }
    }

    @Override
    public List<Categoria> buscarTodos() {
        return getSimpleJdbcTemplate().query(
                "select id,nombre from categorias",
                new BeanPropertyRowMapper<Categoria>(Categoria.class));
    }

 
    @Override
    public List<Categoria> buscarPorNombre(String nombre) {
        try {
            Map<String,String> parametros = new HashMap<String,String>();
            parametros.put("nombre","%"+nombre+"%");
            return getSimpleJdbcTemplate().query(
                    "select * from categorias where nombre like :nombre",
                    new BeanPropertyRowMapper<Categoria>(Categoria.class),parametros);
        } catch (EmptyResultDataAccessException e) {
            return null;
        }
    }
}